// pages/shoplist/shoplist.js
Page({


  //页面的初始数据
  data: {
    query:[],         //页面标题
    shopList:[],      //商品列表
    page:1,           //第几页
    pageSize:10,      //页面数据
    total:0,          
    isloading:false,    //声明一个节流阀,false表示当前没有任何数据请求
  },


  //生命周期函数--监听页面加载
  onLoad: function (options) {
    this.setData({
      query:options
    })
    this.getShopList()
  },

  getShopList(cb){
    this.setData({
      isloading:true    //正在进行数据请求
    })
     
    //需要展示Loading效果
    wx.showLoading({
      title: '数据加载中...',
    })

    wx.request({
      //``反引号请求数据,单引号无法请求数据
      url: `https://www.escook.cn/categories/${this.data.query.id}/shops`,
      method: 'GET',
      data: {
        _page: this.data.page,
        _limit: this.data.pageSize
      },
      success: (res) => {
        // console.log(res);
        this.setData({
          shopList: [...this.data.shopList, ...res.data],
          total:res.header['X-Total-Count'] - 0,
        })
      },
      complete: () => {
        wx.hideLoading()  // 隐藏loading效果
        this.setData({
          isloading:false
        })
        
        cb && cb()
        //关闭下拉刷新窗口  wx.stopPullDownRefresh()
        
      }
    })
  },


  //生命周期函数--监听页面初次渲染完成
  onReady: function () {
    wx.setNavigationBarTitle({
      title: this.data.query.title
    })
  },


  //生命周期函数--监听页面显示
  onShow: function () {

  },


  //生命周期函数--监听页面隐藏
  onHide: function () {

  },


  //生命周期函数--监听页面卸载
  onUnload: function () {

  },


  //页面相关事件处理函数--监听用户下拉动作
  onPullDownRefresh: function () {
    //需要重置关键数据
    this.setData({
      page:1,
      shopList:[],
      total:0
    })
    //重新发起数据请求
    this.getShopList(() => {
      wx.stopPullDownRefresh()
    })

  },

  //页面上拉触底事件的处理函数
  onReachBottom: function () {
    if(this.data.page * this.data.pageSize >= this.data.total){
      //证明没有下一页数据
      return wx.showToast({
        //调用显示消息提示框
        title: '数据加载完毕',
        icon: 'none'
      })
    }
    //判断节流阀的值,从而对数据请求进行节流控制,如果节流阀的值为true,则阻止当前请求;false则发起数据请求
    if(this.data.isloading) return
    this.setData({
      page: this.data.page + 1,
    })
    this.getShopList()
  },


  //用户点击右上角分享
  onShareAppMessage: function () {

  }
})